#define _CRT_SECURE_NO_WARNINGS 1

#include <stack>
using namespace std;

class MinStack {
public:
    MinStack() {

    }

    void push(int val) {
        if (_minst.empty() || _minst.top() >= val)
            _minst.push(val);
        _st.push(val);
    }

    void pop() {
        if (_minst.top() == _st.top())
            _minst.pop();
        _st.pop();
    }

    int top() {
        return _st.top();
    }

    int getMin() {
        return _minst.top();
    }

    stack<int> _st;
    stack<int> _minst;
};